<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"            
      xmlns:p="http://primefaces.org/ui">

    <ui:composition template="/pages/core/plantilla/plantillaPrincipal.xhtml">

        <ui:define name="contenido">          
            <h:form onsubmit="return checkSubmit();"  id="frmPrincipal">        
                <p:panel id="pgFormFilter" header="#{i18n['panel.titulo.terceros']}" style="#{applicationMBean.estiloTitulo}">
                    <h:panelGrid columns="8" cellspacing="5">
                        <h:outputLabel value="#{i18n['general.label.id']}" styleClass="label"/>
                        <p:inputText value="#{terceroMBean.dtoFiltro.id}" onkeypress="return fn_validaTecla('entero',this)" style="#{applicationMBean.estilo}" size="15">
                            <f:validateLongRange minimum="0" maximum="999999" />
                        </p:inputText>
                        <h:outputLabel value="#{i18n['terceros.nombre.razon.social']}" styleClass="label"/>
                        <p:inputText label="#{i18n['terceros.nombre.razon.social']}" 
                                     value="#{terceroMBean.dtoFiltro.nombres}" 
                                     style="#{applicationMBean.estilo}" size="60">
                            <f:validateLength maximum="50" minimum="0" />
                        </p:inputText>
                        <h:outputLabel value="#{i18n['terceros.numero.docuemnto']}" styleClass="label"/>
                        <p:inputText label="#{i18n['terceros.numero.docuemnto']}" onkeypress="return fn_validaTecla('entero',this)"
                                     value="#{terceroMBean.dtoFiltro.numeroDocumento}" maxlength="30" 
                                     style="#{applicationMBean.estilo}" size="60">
                        </p:inputText>
                        <h:outputLabel styleClass="label" value="#{i18n['terceros.tipo.documento']}"/>
                        <p:selectOneMenu value="#{terceroMBean.dtoFiltro.tipoDocumentoDto}"  converter="parametroConvert"                                  
                                         style="#{applicationMBean.estiloObligatorio}">
                            <f:selectItems value="#{terceroMBean.listaDocumentosFiltro}" var="parametroDto" itemLabel="#{parametroDto.descripcion}" itemValue="#{parametroDto}" />                        
                        </p:selectOneMenu>
                        <h:outputLabel styleClass="label" value="#{i18n['terceros.pais']}"/>                    
                        <p:selectOneMenu value="#{terceroMBean.dtoFiltro.paisDto}"  converter="ubigeoConvert"                                  
                                         style="#{applicationMBean.estiloObligatorio}">
                            <f:selectItems value="#{terceroMBean.listaPaisesFiltro}" var="ubigeoDto" itemLabel="#{ubigeoDto.descripcion}" itemValue="#{ubigeoDto}" />                        
                        </p:selectOneMenu>
                        <h:outputLabel styleClass="label" value="#{i18n['terceros.sexo']}"/>
                        <p:selectOneMenu value="#{terceroMBean.dtoFiltro.sexo}" style="width:120px;">
                            <f:selectItem itemLabel="*" itemValue="#{null}"/>
                            <f:selectItem itemLabel="MASCULINO" itemValue="M"/>
                            <f:selectItem itemLabel="FEMENINO" itemValue="F"/>
                        </p:selectOneMenu>
                        
                        <h:outputLabel styleClass="label" value="#{i18n['terceros.estado']}"/>                       
                        <p:selectOneMenu  value="#{terceroMBean.dtoFiltro.estadoDto}" converter="parametroConvert">
                            <f:selectItems value="#{terceroMBean.listaEstados}" var="parametroDto" itemLabel="#{parametroDto.descripcion}" itemValue="#{parametroDto}"/>
                        </p:selectOneMenu>
                        
                        <h:outputLabel styleClass="label" value="#{i18n['terceros.cliente']}"/>                    
                        <p:selectBooleanCheckbox value="#{terceroMBean.dtoFiltro.cliente}"  style="#{applicationMBean.estilo}" />
                        <h:outputLabel styleClass="label" value="#{i18n['terceros.proveedor']}"/>                    
                        <p:selectBooleanCheckbox value="#{terceroMBean.dtoFiltro.proveedor}"  style="#{applicationMBean.estilo}"/>
        
                    </h:panelGrid>
                    <f:facet name="footer">

                        <p:commandButton icon="ui-icon ui-icon-search" title="#{i18n['general.button.buscar.filtro.tip']}" accesskey="#{applicationMBean.keyBuscar}"
                                         value="#{i18n['general.button.buscar.filtro']}" ajax="false" 
                                         style="#{applicationMBean.estilosBtnBuscar}"
                                         actionListener="#{terceroMBean.buscar}">
                            <f:ajax  render="pnlTabla pgFormFilter"/>
                        </p:commandButton>  

                        <p:commandButton title="#{i18n['general.button.nuevo.tip']}" accesskey="#{applicationMBean.keyNuevo}"
                                         icon="ui-icon ui-icon-plus"
                                         style="#{applicationMBean.estilosBtnNuevo}" 
                                         value="#{i18n['general.button.nuevo']}" 
                                         ajax="false"                                        
                                         action="#{terceroMBean.nuevo}">                                    
                        </p:commandButton>   
                        <p:spacer width="20" />
                        <h:outputText  value="#{terceroMBean.lista.size()} #{i18n['form.general.mensaje.cantidad.encontrada']}" styleClass="mensaje" rendered="#{terceroMBean.lista!=null}"/>
                    </f:facet>
                </p:panel>  

                <p:panel id="pnlTabla" header="#{i18n['general.panel.titulo.busqueda.resultado']}"  style="#{applicationMBean.estiloTitulo}" rendered="#{terceroMBean.lista!=null &amp;&amp; terceroMBean.lista.size()>0}">
                    <h:panelGrid>
                        <p:dataTable id="tblPrincipal" value="#{terceroMBean.lista}" var="dto" paginatorPosition="top"                                     
                                     paginator="true" rows="#{sessionMBean.cantidadRegistros}"  widgetVar="widTable">                        
                            <p:column >         
                                <p:commandButton icon="ui-icon ui-icon-search" title="#{i18n['general.button.ver.tip']}"
                                                 action="#{terceroMBean.ver}" ajax="false">
                                    <f:setPropertyActionListener value="#{dto}" target="#{terceroMBean.dto}" />                                                                    
                                </p:commandButton>
                                <p:commandButton icon="ui-icon ui-icon-pencil" title="#{i18n['general.button.editar.tip']}"
                                                 action="#{terceroMBean.editar}" ajax="false">
                                    <f:setPropertyActionListener value="#{dto}" target="#{terceroMBean.dto}" />                                                                    
                                </p:commandButton>
                            </p:column>

                            <p:column headerText="#{i18n['general.label.id']}"  styleClass="general">
                                <h:outputText value="#{dto.id}" styleClass="general" />
                            </p:column>
                            <p:column headerText="#{i18n['terceros.nombre.razon.social']}" styleClass="general">
                                <h:outputText value="#{dto.descripcion}" styleClass="general" />
                                
                            </p:column>
                            <p:column headerText="#{i18n['terceros.tipo.documento']}" styleClass="general">
                                <h:outputText value="#{dto.tipoDocumentoDto.descripcion}" styleClass="general" />
                            </p:column>
                            <p:column headerText="#{i18n['terceros.numero.docuemnto']}" style="#{applicationMBean.estiloMontosDerecha}" styleClass="general">
                                <h:outputText value="#{dto.numeroDocumento}" styleClass="general" />
                            </p:column>
                            <p:column headerText="#{i18n['terceros.cliente']}" styleClass="general">
                                <h:outputText value="#{dto.clienteTexto}" styleClass="general" />
                            </p:column> 
                            <p:column headerText="#{i18n['terceros.proveedor']}" styleClass="general">
                                <h:outputText value="#{dto.proveedorTexto}" styleClass="general" />
                            </p:column> 
                            <p:column headerText="#{i18n['terceros.pais']}" styleClass="general">
                                <h:outputText value="#{dto.paisDto.descripcion}" styleClass="general" />
                            </p:column> 
                            <p:column headerText="#{i18n['terceros.estado']}" styleClass="general">
                                <h:outputText value="#{dto.estadoDto.descripcion}" styleClass="general" />
                            </p:column>
                        </p:dataTable>        
                    </h:panelGrid>
                </p:panel>


            </h:form>
        </ui:define>
    </ui:composition>
</html>
